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(54) Signal processing apparatus and method for processing signals 



(57) According to the present invention, an LFSR 
(300) has a propagation path (30) of serially coupled 
stages (65) and gates (80-3, 80-4). a feedforward path 
(10) of gates (80-1) and a feedback path (20) of gates 
(80-2). Depending on control signals (P. B, M), the gates 
(80-1, 80-2, 80-3. 80-4) are either active gates and 
operate as xor-gates or passive gates and operate as 
transfer gates. Feedforward and feedback signals are 



derived from input and output signals and can be sup- 
plied to any stage (65). so that characteristic polynomi- 
als of the input-output function are variable. The LFSR 
can fully or partly operate as a TYPE 1 or TYPE 2 LFSR 
which enables the execution of different algorithms on 
one hardware base. 
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freti ftf tha invention 

5 This invention relates to electronic devices, and especially to a linear feedback shift register (LFSR) as a device tor 
processing codes and to a method used therein, 

fiflcjfflrQwti Qf the InvgpMfiO 

10 Linear Feedback Shift Registers (LFSR) are used in digital communication and other systems tor data processing 
such as, for example, ciphering, error detecting, error correcting, or for generating pseudo random sequences. In an 
LFSR, a plurality of stages is coupled for sequential propagation of signals through the stages. The signal propagation 
can be influenced by exc/us/ve-or -gates (xor-gates) arranged according to characteristic polynomials of an input-out- 
put function, 

15 The theoretical background for using LFSRs in, e.g., a message encoder, is explained in chapter 5.6. of Sklar, B.: 
Digital Communications, Fundamentals and Applications. Prentice Hall, Englewood Cliffs. New Jersey, ISBN 0-13- 
211939-0 [1]- 

LFSRs can be classified into TYPE 1 and TYPE 2. This classification has been explained US. patent 5,073,909 to 
Kotzin et. al. [2] in reference to LFSR which are used to generate random sequences. LFSRs which read input signal 

so IN and provide output signal OUT are now explained by way of example in FIGS. 1 -2. FIG. 1 shows prior art LFSR 100 
of TYPE 1. LFSR 100 comprises stages 111. 112, 113. 114 and xor-gates 1 1 5 and 116. IN is supplied to xor-gate 115 
and then propagated through stages 111-1 14. OUT is available at the output of stage 1 14. Signal T1, obtained from 
xor-gate 1 16 acting upon the outputs of stages 113 and 1 14. T1 is then fed back to the input of stage 1 1 1 through xor- 
gate 1 5. TYPE 1 , as used herein, defines an LFSR wherein the various stages (e.g.. 111-114) are cascaded together, 

25 input to output, without interruption by an intervening signal (e.g., T1). TYPE 1 LFSRs are commonly used to implement 
algorithms for, e.g.. the generation of a mask set sequence for data ciphering. 

FIG. 2 shows prior art LFSR 200 of TYPE 2. LFSR 200 comprises stages 221 , 222. 223. 224, and xor-gates 225 
and 226. IN is supplied to xor-gate 225 and then propagated through stage 221. xor-gate 226, and stages 222-224. 
OUT is available at the output of stage 224. Xor-gate 226 performs an exciusive-or operation on the outputs of stages 

30 221 and 224. This operation is then used to determine the state of stage 222. Finally, the output of stage 224 is fed back 
to xor-gate 225. TYPE 2, as used herein, defines an LFSR wherein the various stages (e.g., 221-224) are cascaded 
together, however, the shift path is interrupted by the introduction of a signal (e.g.. T2). TYPE 2 LFSRs are commonly 
used to implement algorithms for e.g„ for parity code generation, error detection and error correction. 

As is used herein and only for the convenience of explanation, a first direction is defined for signals going from ele- 

35 ments (stages or xor-gates) with low reference numbers (e.g., 1 1 1) to elements with higher reference numbers (e.g., 
1 14). A second direction is defined in the opposite way. As shown in the figures, the first direction goes from left to right 
and the second direction goes from rightto left. For example, in FIG. 1, IN goes in first direction to OUT. T1 goes in sec- 
ond direction from xor-gate 1 1 6 to xor-gate 1 1 5. T1 can therefore be considered as feedback signal. Although the term 
LFSR implies feeding "back" signals (e.g., T1, T2 of FIGS. 1-2), LFSRs as discussed here can also feed forward sig- 

40 nals. 

In LFSRs 100 and 200 as shown in FIGS. 1 -2, the stages and xor-gates are hard wired so that the characteristic 
polynomials of the LFSR can not be changed. However, there are instances in circuit design where one application 
(e.g.. a cellular phone) needs variable characteristic polynomials. Operators for phone systems may use their own pro- 
prietary polynomials for e.g. , data ciphering. It is easier to market phones having similar hardware but different software 
45 than market phones having different hardware. Further, some applications require different data processing algorithms 
at different times. In view of hardware expenses and power consumption, it is not convenient to have separate LFSRs 
(TYPEs 1 and 2) for different algorithms. There is a need to design a LFSR able to provide both TYPE 1 and TYPE 2 
features. 

Figure 4 of U.S. patent 5.446,683 to Mullen et. al. [1) shows an LFSR incorporating provisions for variation of the 
so characteristic polynomial. However, the LFSR is of TYPE 1 and cannot be reconfigured to TYPE 2. The present inven- 
tion seeks to provide a fully programmable LFSR with variable characteristic polynomials which is switchable between 
TYPE 1 and TYPE 2. 

grief Pegcriptic-n of the Drawings 

55 

FIG. 1 shows a simplified block diagram of a prior art linear feedback shift register (LFSR) of TYPE 1 ; 
FIG. 2 shows a simplified block diagram of a prior art LFSR of TYPE 2; 

FIG. 3 shows a simplified block diagram of an LFSR in a preferred embodiment of the present invention; 
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FIG. 4 shows a simplified blocK diagram of a cell as used in the LFSR of FIG. 3; 
FIG. 5 shows a simplified biock diagram of a gate as used in the cell of FIG. 4: 

FIG. 6 shows simplified block diagrams of ceils of FIG, 4 configured for operating the LFSR of FIG. 3 in a TYPE-1- 
MODE; 

FIG. 7 shows simplified block diagrams of cells of FIG, 4 configured for operating the LFSR of FIG. 3 in a TYPE-2- 
MODE; and 

FIG. 8 shows a logic arrangement as it can also be used in cell 40. 



Detailed Descri ption of a Preferred Embodiment 

w 

The LFSR according to a preferred embodiment of the invention is illustrated by way of example in FIGS. 3-8, At 
first, the elements (e.g., cells, stages, gates) of the LFSR and their connections are explained in a top down view, from 
FIGS. 3 to 5. Second, the function of the LFSR is explained in a bottom up view, by FIGS, 5 to 3 and FIGS. 6-7. Third, 
it will be explained, how the LFSR can operate as LFSRs of FIGS, 1-2. FIG. 8 shows additional details. 

i$ For explanation and not intended to be limiting, signals are considered as binary signals having first and second 
logical states abbreviated as logical "1" and "0", respectively, In the text, signals are abbreviated by uppercase letters 
and acronyms (e.g.. A. C, F, L, R, S, C. X R. PB, PF). Logical functions known in the art are given in lowercase bold 
italics (e.g., xor, and). The elements have arabic reference numbers (e.g., 40). Some elements (e.g., cells) and signals 
(e.g., of signal vectors) are. preferably, available in pluralities. A single element or signal is referenced by an index, 

so wherein elements and signals of a plurality are collectively referred without index. For elements, indices are attached to 
the numbers by a hyphen (e.g., 40-i t 40-2). For signals, indices are written as subscripts (e.g., P t . PB^). Unless other- 
wise stated, index i can have any value between 1 and n. For convenience of explanation, a preferred embodiment of 
the present invention is illustrated in FIG. 4 wherein k=4, but other values are possible for other implementations. There 
is no need to have a'/ elements or signals with all possible values of i or k. Optionally, elements and signals can be left 

25 out. Indices can include sums or differences (e.g.. i-1 . i+1). For simplicity, connections for carrying clock signals to the 
elements are not shown. Persons ol skill in the art will understand how to provide clock signals, 

FIG. 3 shows a simplified block diagram of linear feedback shift register 300 (dashed frame, hereinafter LFSR 300) 
in a preferred embodiment of the present invention. LFSR 300 comprises a plurality of cells 40. and optional xor-gate 
70. For simplicity, in FIG. 3, only celts 40-1. 40-1. 40-i and 40-n are shown. Bus 50 at terminal 51 provides control sig- 

30 nats to cells 40 at connections 52-1 to 52-n. Dashed connections in cells 40 illustrate a signal transfer through ceils 40. 
As it will be explained in connection with FIGS. 4-5, cells 40 have gates which can be enabled or disabled by the control 
signals from bus 50 so that the signal transfer can be modified. Xor-gate 70 has inputs 71 and 72 and output 73 for 
relating signals by a xor-operation known in the art. Connections 30-i (i=0 to n+1) through xor-gate 70 and cells 40, 
preferably, couple, terminals 31 and 32. Connections 30 form thereby a propagation path for propagating data signals 

35 Aj (i=0 to n+1). Connections 10-i (i=1 to n=m+1) through cells 40, preferably, couple terminals 1 1 and 12 and form a 
feedforward path with data signals R ( (i=1 to n). Connections 20-i (i=n down to 0) through ceils 40. preferably, couple 
terminals 21 and 22 and form a feectoack path with data signals l_j (i=n down to 0). Arrows on connections 10. 20. 30 
here and in other figures show the preferred direction of signal flow. The terms forward' and "back* are convenient 
abbreviations for the above mentioned first direction (e.g., increasing i) and second direction (e.g., decreasing i), 

40 respectively, that is, for referring to opposed directions of signal propagation through the LFSR. 

Having the paths implemented by connections 10, 20, 30 going over the full range of indices i, is convenient for 
explanation, but not necessary for the invention. Connections 10, 20, and 30 can be shorter, so that for example, termi- 
nals 1 1 . and 12 can be coupled to connections 10-2 and 10-5, respectively. It will be explained later, how cells 40 couple 
connection 30 to connections 10 and 20. As shown in FIG. 3 only for convenience and not intended to be limiting, it is 

as assumed that connection 20 is coupled to input 72 and that connection 30 is coupled to connection 20 via connection 
35 going through terminals 32 and 21 . 

Preferably, LFSR 300 receives, e.g,, Aq as input signal and sequentially propagates H in the first direction to e.g.. 
Ap+n as an output signal. Thereby, feedforward and feedback signals (e.g.. R f , U) go through cells 40 in the first (increas- 
ing i) and second (decreasing i) directions. Output signals (e.g., R m , L 1f and A„ +1 ) can be obtained at any of connec- 

so tions 10. 20, or 30 having any index i. The input signal is related to the output signal by an input-output function which 
has variable characteristic polynomials. The input-output function is determined by a plurality of control signals in bus 
50. Control signals can be e.g., polynom signals PB jr PFj (collectively P), mode signals M1, M2 (collectively M), where 
"F" and "B" in combination with "P" refer to forward and backward propagation directions. Polynom signals form a first 
polynom vector (PF with ag., PF-, to PFJ and a second polynom vector (PB with e.g., PB, to PB m ). Sequences of 

55 LFSR 300 or the complete LFSR 300 can be switched between a TYPE-1 -MODE and a TYPE-2-MODE by selectively 
activating and de-activating the gates in the propagation path. 

FIG. 4 shows a simplified block diagram of cell 40 (dashed frame) as used in LFSR 300. Connections 10, 20 and 
30 and connections 52 correspond in FIGS. 3-4. Cell 40 comprises stage 65 and gates 80-1, 80-2, 80-3, and 80-4. 
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Stage 65 is a storage means for receiving a signal at input 66 and propagating it to output 67. Stage 65 can be imple- 
mented by, lor example, a D-type flip-flop known in the art. Preferably, each gate 80 has inputs 81 , 82, 83, 84 and output 
86. Gate 80 is described further in connection with FIG, 5. 

In the propagation path, connection 30-i is coupled to input 66. Output 67 is coupled to inputs 82-1 , 82-2 and 81-3 
forming connection 30*-i. Output 86-3 is coupled to input 81-4 forming connection 30 M -i and output 86-4 is coupled to 
connection 30-(i+ 1). in the feedforward path, connection 10-i is coupled to input 81-1 , and output 86-1 leading into con- 
nection 10-(I+1) is coupled to input 82-3. In the feedback path, connection 20-i is coupled to input 81-2 and to input 82- 
4. Output 86-2 leads to connection 20-(i-1 ), Connections 431 , 432, 433 and 434 originate from connection 52 and carry 
control signals, Connection 431 is coupled to input 84-1 and to input 84-3. Connection 432 is coupled to input 84-2 and 
to input 84-4. Connection 433 is coupled to input 83-1 and to input 83*2. Connection 434 is coupled to input 83-3 and 
to input 83-4. As tar as a logical xor-operation is commutative, gates 80-3 and 80-4 can be arranged in a different order. 
Gate 80*3 and 80-4 form logic arrangement 45 (dashed frame). 

FIG. 5 shows a simplified block diagram of gate 80 (dashed frame) as used in cell 40 of FIG. 4. Reference numbers 
81, 82, 83, 84 and 86 in FIG. 5 correspond to these of FIG. 4. Gate 80 comprises antf-gate 75 and xor-gate 76. Xor- 
gate 76 has first data input 81. Xor-gate 76 has input 87 coupled to output 85 of an^gate 75. An^gate 75 has first 
control input 83, second control input 84, and second data input 82, 

Gate 80 receives control signal M at input 83 and control signal P at input 84. Gate 80 receives first data signal F 
at input 81 and second data signal S at input 82. Gate 80 relates these signals to third data signal Y according to a log- 
ical function Y » f (M, P, S. F) t as for example: 

Y = ( M and P andS ) xor R (1 ) 

25 with xof standing for a logical exclusive disjunctive operation and and for a logical conjunctive operation. Gate 80 is 
in an active state ("active gate", "enabled gate") for ( M and P ) ="r and in a passive state ("passive gate", "disabled 
gate") for ( M and P ) *"0". For convenience of explanation, control signals M and P can be combined to control signal 
C which is defined as: 



20 



30 



35 



C = Ma/id P. (2) 

Function (1) can be simplified to: 

Y = (C and S) xor F. (3) 



For active gate 80, equation (1) becomes: 

*> Y = p" and S) xor F. 

Y = S xor F. (4) 

45 For passive gate 80, equation (1 ) becomes: 

Y = ("0" and S ) xor F 

so Y = F. (5) 



Table 1 is a truth table for gate 80 showing the logical relation of control signals M, and P at inputs 83, 84 (columns 
55 1-2), and data signals F and S at inputs 81. 82 (columns 3-4) to data signal Y at output 86 {column 5). The term "any" 
stands for either logical "1" or "0" states of the signals. Configurations for active gates 80 are shown in rows 1-4, when 
both M and P are at logical "1" . Active gate 80 operates as a xor-gate (Y xorf). Configurations for passive gate 80 are 
shown in rows 5-8 when either M or P or both are at logical "0". Passive gate 80 behaves like a conductor (e.g., a trans- 
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fer gate) transferring F to Y without changing the logical state and without influence from S. Having active and passive 
states, gate 80 can be considered as a conditional xor-gata 



Table 1: Operation of gate 80 
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In cell 40 (FIG. 4), control signal M1 at connection 433 is supplied to inputs 83-1 and 83-2 and M2 at connection 

40 434 is supplied to inputs 83-3 and 83-4. Control signal PFj at connection 431 is supplied to inputs 84-1 and 84-3. Con- 
trot signal PBj at connection 432 is supplied to inputs 84-2 and 84-4. In the propagation path, delay stage 65 receives 
A* at connection 30-i and provides after a delay to connection 30*-i. Signal Aj - is also expressed as A/z, with the 
term "1/z" indicating a delay as known in connection with z-transformations. Gate 80-3 receives Af a * input 81-3 and 
R^t at input 82-3 and provides Aj** « f (M2, PFj, Rj^, A*) at output 86-3 to connection 30**-i. Gate 80-4 receives Aj** 

45 at input 81-4 and l^ at input 82-4 and provides A i+1 = f ( M2, PBj, Lj, Aj**) at output 86-4 to connection 30-(i+1). in the 
feedforward path, gate 80-1 receives Rj at input 81-1 from connection 10-i and Aj* at input 82-1 and provides data signal 
= f ( M1, PFj, Aj*, Rj ) at output 86-1 to connection 10-(i+1} according to equation (1). In the feedback path, gate 
80-2 receives Lj at input 81 -2 from connection 20-i and Aj* at input 82-2 and provides L+n « f ( M1 , PBj, A t *. Lj) at output 
86-2 to connection 20-(i-1) according to equation (1). 

so First it is assumed that cell 40 receives M1 ="1 - and M2= M 0 M , Thereby, gates 80-3 and 80-4 pass data signals with- 
out changing them so that A i+1 =Aj*=Aj**=Aj (equation (5)). R^ and Lj have no influence. For explanation, the connec- 
tions going to inputs 82-3 and 82-4 can therefore be considered as being non-exisling. For PFj^l gate 80-1 provides 
R M = Aj* xor Rj (active gate, equation (4)). For PFj="0", gate 80-1 provides R j+1 =Rj (5). Depending on PBj. gate 80-2 
provides Lj +1 =Aj* xor Lj (4) or provides U--\*U- With this configuration, cell 40 is suitable to operate in a TYPE 1 LFSR. 

55 Second it is assumed that ceil 40 receives M1="0" and M2=T. Thereby, gates 80-1 and 80-2 pass data signals 
without changing them so that R^n=Rj and Lj.i=Lj (equation (5)). Aj* has no influence to inputs 82-1 and 82-2 and con- 
nections going to that inputs can be neglected. For PFpT, gate 80-3 provides Aj**aR i+1 xor Aj* (active gate, equation 
(4)). For PFj="0 H , gate 80-3 passes Aj*: Aj**=Aj* (5). For PBj="1 gate 80-4 provides Aj=Lj xor Aj** (4). For PBj^O", gate 
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80-4 passes A,**: A t+t «Aj** (5). For PF ja .PBj*"r. A" can be substituted and A +1 calculated as A i+1 »L( xor (R w1 xor 
Aj'). Considering the linearity of the logical xor-operation, A kl can also be expressed as A, +1 »Af xor {l s xor R^). 

In cells 40 as shown in the example of FIG. 4, a signal from the propagation path (i.e., A/ at connections 3QAi) is 
supplied to the forward path (connections 10) by a second inputs 82 of gate 80-1 , The signal is supplied to the feedback 

5 path (connections 20) by second input 82 of gate 80-2. Inside the propagation path (connections 30), signals are trans- 
mitted through the first inputs 81 -3 and 81-4. Inside the forward and feedback paths (connections 10, 20), signals are 
transmitted through the first inputs 81-1 and 81-2. 

For further explanations, control signals PF |( PB jt M1 and M2 are substituted according to definition (2) to control 
signals M1 and PFj for gate 80-1 . C 2 * Ml and PB; for gate 80-2, C 3 * M2 and PFj for gate 80-3 and C 4 = M2 and 

w P8j for gate 80-4. Control signals C t to C 4 can be supplied to cells 40 instead of M and P h The signals at the ^-connec- 
tions" (input side) and at the *(kt)/(H*1 Connections" (output side) of cell 40 are given in table 2. Equations (6) to (9) 
describe the logical relation between the connections of cell 40. 



Table 2: Operation of cells 40 
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xor (R M and C 3 ) 
xor (L, and C 4 ) (6) 
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(6) for C^-0". C z ="0": 
A i+ ,= A/2 
xor (R, and C 3 ) 




35 






xor (L, and C 4 ) (7) 
(6) for C 3 -"0", C 4 ="0": 
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A l+1 =A/z (8) 
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R )+1 = (A/z and C,) xor R, (9) 
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L M = (A/z and C 2 ) xor L, (10) 
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Equation (6) describes the signal propagation from at least a first cell 40-1 to a second cell 4G-(i+1). Equation (6) 
can he implemented by, for example, logic arrangement 45 of FIG. 4 having (cf. FIG. 5) at least a first xor-gate (e.g.. 
55 xor-gate 76 of gate 80-3) and a second xor-gate (ag., xor-gate 76 of gate 80-4). a first a/itf-gate (e.g. . annate 75 of 
gate 80-3) and a second and-gate (e.g., and-gate 75 of gate 80-4). Equation (6) can be re-written without departing 
from the scope of the present invention, as for example to: 
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4 

A u ,= A/z xor ( (C 4 and L.) xor (C 3 and R„,) ) (11) 



5 

An implementation example of (11) is illustrated in FIG, 8, Based on the description herein, a person of skill in the art 
can use Boolean algebra to implement equation (6) by other means and, eventually, with additional logic (e.g,, n&nd< 
nor, or or-gates, inverters) or other components (such as e.g., multiplexers). The present invention is intended to 
include such alternatives. In the propagation connection, only two xor-gates (in connections 30-i t 30H 30*H 30-0+1) 

jo ) are required between stage 65-i of cell 40-i and stage 65i+l of the next ceil 40*(i-f 1). 

As in equation (7) f which is a simplification of (6) for TYPE-2-MODE operation, the propagation path (signal A } ) can 
be modified from both the feedback path (e.g., signal Lj) and from the forward path (e.g.. signal Rj), For TYPE-1-MODE 
operation, the propagation path is preferably, not modified (equation (8)). 

FIG. 6 shows simplified block diagmn>s of cells 40 configured for operating the LFSR 300 in the TYPE-t-MODE. 

is Cells 40 are distinguished by their configurations #10, #11. #12 and #13. For convenience, connections 10, 20, and 30 
(as in FIGS. 3-4) and stage 65 are given. Gates 80 operating according to equation (5) are symbolized as a conductors. 
Gates 80 operating according to equation (4) are shown by an xor-symbol (V in a circle). 

For example, and not intended to be limiting, table 3 gives possible states (e.g., T, "0") for PF and PB and config- 
urations for ceil 40 which are determined by PF and PB. Also, the operation of gates 80-1 to 80-4 is given by the terms 

so xor" (equation (4)) and 'equal (equation (5), conductor). Control signal M is assumed to be at, e,g„ logical *V. 



Table 3 



Cell-configurations for TYPE- 1 -MODE 


configuration 


#10 


#11 


#12 


#13 


PF 


"0" 


, r 


"0" 




PB 










gate 80-1 


equal 


xor 


equal 


xor 


gate 80-2 


equal 


equal 


xor 


xor 


gate 80-3 


equal 


equal 


equal 


equal 


gate 80-4 


equal 


equal 


equal 


equal 



In configuration #1 1 . the forward path is modified and the feedback path is not modified. In configurations #12, the 
feedback path is modified and the forward path is not modified. In configuration #13 both forward and feedback paths 
are modified, in other words, active gates 80 located in the forward or feedback paths modify them, wherein passive 

40 gates 80 pass signals unchanged. 

FIG. 7 shows simplified block diagrams of ceils 40 configured for operating LFSR 300 in the TYPE-2-MODE. Cells 
40 are distinguished by their configurations #20, #21 , #22 and #23. Gates 80 operating according to equation (5) are 
symbolized as a conductor and therefore not specially numbered. Gates 80 operating according to equation (4) are 
shown by an xor-symbol ("+" in a circle). 

45 For example, and not intended to be limiting, table 4 gives possible states (e.g., T, "0") for PF and PB and config- 
urations for cell 40 which are determined by PF and PB. Also, the operation of gates 80-1 to 80-4 is given by the terms 
*xof (equation (4)) and 'equaf (equation (5))- Control signal M is assumed to be at e.g., logical "0". 



Cell-configurations for TYPE-2-MODE 



configuration 


#20 


#21 


#22 


#23 


PF 


"0* 


* r 


"0" 


*^ * 


PB 


"0** 


"0" 


T 


T 


gate 80-1 


equal 


equal 


equal 


equal 



7 



BNSDOCID: <EP 0B87930A2 J.„> 



EP 0 887 930 A2 



Table <* (continued) 



Cell-configurattons for TYPE-2-MODE 


configuration 


#20 


#21 


#22 


#23 


gate 80-2 


equal 


equal 


equal 


equal 


gate 80-3 


equal 


xor 


equal 


xor 


gate 80-4 


equal 


equal 


xor 


xor 
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In configuration #21, the propagation path is modified by signals coming from the unmodified forward path. In con- 
figuration #22, the propagation path is modified by signals coming from the unmodified feedback path. In configuration 
#23, the propagation connection is modified from both forward and feedback paths. In other words, when gates 80 
located in the propagation paths are active, then signals are modified, wherein passive gates 80 pass signals 
, 5 unchanged. 

The cell configurations of FIGS. 6-7 are not limited to four configurations in each mode. With a number of four gates 
80 each being either active or passive, a number of 16 different configurations is possible. As it will be shown later, the 
gates in cell 40 can be arranged in a different way, so that more configurations can be added. 

The function of LFSR 300 is now explained by way of examples, LFSR 300 can behave as prior art TYPE 1 LFSR 

so 100 of FIG, 1. In that case LFSR 300 has three cells 40-1 , 40*2, and 40-3 (m=3) corresponding to stages 1 1 1 , 1 1 2, and 
113 of FIG. 1. Xo/vgate 70 {FIG. 3) corresponds to xor-gate 1 1 S of FIG. 1 , and stage 65-n (FIG. 3 for n**) corresponds 
to stage 1 1 4. Control signals M1 and M2 are at logical "1 u and "0", respectively, to set the first mode (TYPE-1 -MODE). 
Control signals PB are PB^r, and PB 1 =PB 2 «"0". The other control signals PF,^ 3 are at logical "0\ With this control 
signals, ceils 40-1 and 40-2 are configured as cell 40#10. Cell 40-3 has configuration #12. Active gate 80-2 in cell 40* 

25 3 corresponds to iror-gate 1 1 6 in FIG. 1 . The resulting LFSR 300 is therefore structural and functional similar to LFSR 
100. Feedback signal T1 (cf. FIG. 1) from a modified feedback connection (cell 40-3) goes through unmodified feedback 
connections of cells 40-1 and 40-2 to xor-gate 70. 

Now. LFSR 300 can be switched to TYPE 2 LFSR 200 of FIG. 2. Four cells 40-1, 40-2, 40-3. and 40-4 (n=-4) corre- 
spond to stages 221 . 222. 223. 224 of FIG. 2. Xor-gate 70 (FIG. 3) corresponds to xor-gate 225 of FIG. 2. Control sig- 

30 nals M1="0" and M2="r set second mode TYPE-2-MODE. Control signals are PB^r and PB2 3 4="0 M and 
P F 1 .2,3.4="0* Cells 40-2, 40-3 and 40-4 have the configuration #20. Cell 40-1 has active gate 80-4 which results in con- 
figuration #22. The resulting LFSR 300 is structural and functional similar to LFSR 200. 

In general, gates 80-k of cells 40-i to m) can be classified into a first set {index k=1). a second set (k=2), a third 
set (k=3 and k=4) of gates. When LSFR 300 operates in TYPE-1-MODE. the first set provides data propagation in the 

35 first direction (feeding forward) and the second set provides data propagation in the second direction (feedback). The 
stages of the third set propagate in the first direction. The stages of the first and second set can be activated simulta- 
neously. This features allows, for example, to process data by polynom multiplication and polynom division at the same 
time. 

When LFSR 300 operates in the second mode, the stages of the first and second sets provide data propagation in 
40 the first and second directions only through inputs 81 , but not through inputs 82. The stages of the third set propagate 
data in the first direction. 

LFSR 300 of the present invention can generally be described as a signal processing apparatus which has a first 
path (e.g., connections 30) for propagating a first path signal A (e.g., Aj, A*-,) with signals , A^, A^ (k1 < k2 < k3,. 
e.g., k1=1, k2=2, k3=3) in afirst direction, a second path (e.g., connections 10) for propagating a second path signal R* 
45 (e.g., Rj, R i+1 ) in the first direction and a third path (e.g., connections 20) for propagating a third path signal (e.g., Lj, 
L^) in a second, opposite, direction. LFSR 300 at least comprises means (e.g., bus 50) for receiving first control signal 
C* t (e.g., M1 andPF^, 

second control signal C* 2 (e.g., M1 and PB3), third control signal C* 3 (e.g., M2 and PF 2 ) and fourth control signal C* 4 
(e.g.. M2 and PBa). 

so The first path has at least a first stage (e.g., stage 65 of cell 40-1), a second stage (e.g., stage 65 of cell 40-2), and 
a third stage (ag. , stage 65 of ceil 40-3). The first stage provides signal A k1 (e.g.. A, *) to the second stage. The second 
stage provides signal A^ (e.g., V) to the third stage, and the third stage provides signal A^ (e.g.. A3*). A first logic 
arrangement (e.g., gates 80-3 and 80-4 of cell 40-2) modifies signal A^ to Ak2 +1 = A^ *or(R andC* 3 ) *or(L andC\) 
(cf. 7). The second path has at least a second logic arrangement (e.g., gate 80-1 of cell 40-1 ) which receives signal A^ 

55 (e.g. . an input signal at terminal 1 1 ) and modif ies R k1 to R^ + i = ( A^ and C*-, ) xor R^ (cf . 9). The third path has at least 
a third logic arrangement (e.g., gate 80-2 of cell 40-3) which receives component A,^ and modifying to 1*3.-,= (A^ 
and 0*2) *or L* 3 (cf. 10). Depending on C^. C* 2 and on C* 3 . C* 4 , first, second and third stages and first second, and 
third logic arrangements operate either in a first mode as a TYPE-1 LFSR and in a second mode as a type TYPE-2 
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LFSR. wherein in both modes the polynomial characteristics are determined by CV C* 2 end by C* 3 . C%. 

A method for signal processing in a serial arrangement of cells kO »1 to m (e.g., cells 40-1 to 40-40) with at least a 
first ceil k1 (e.g., 40-10), a second cell k2 (e.g.. 40-20), and a third cell k3 (e.g., 40-30). with K2 £ kl+1, k3 £ k2+1. (e.g., 
k1 p 1 0, k2*=20, k3=30) has the following steps: 

(i) prodding a first control signal C' 1( (e.g.. C-i to cell 40-10), a second control signal C* 2 (e.g., C2 to cell 40-30), a 
third control signal C* 3 (e.g., C 3 to 40*20) and fourth control signal C' 4 (e.g.. C 4 to 40-30); 

(ii) propagating a first path signal A in a first path (e.g., connections 30) through the cells k1. k2 and k3 in a first 
direction; 

10 (iii) propagating a second path signal R in a second path (e.g.. connections 10) through the cells ki and k2 in the 
first direction; 

(iv) propagating a third path signal L in a third path (&g. ( connections 20) through the cells k2 and k3 in a second, 
opposite direction. 

15 During propagation of path signals A, R, L 



ceil 


ki 
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When R is propagated, cell k1 modifies R k1 to Rjtui = (A k1 /z and C%) xor R^. (equation (9) with i=k1 ). R^ is 
30 further propagated to R k2 (e.g., through cell 40-11 to 40-1 9). When A is propagated, celt k2 modifies to A k2+1 = A^z 
xor (Rk2+. and 0*3) xor (L^ and C* 4 ) (equation (6) with i=k2). A k2+1 is further propagated to A^ by e.g., cells 40-21 
to 40-29. When L is propagated, cell k3 modifies to = (A^/Z and C*^ xor (equation (10). L k3 . 1 is further 
propagated to L^ by e.g., ceite 40-29 to 40-21. Output signals can selectively derived from any of the cells. 

Path signals R and L can be propagated substantially simultaneously. For control signals CVCVO". a first 
35 sequence of an arrangement defined by ceils k2 and k3 operates as a TYPE 2 LFSR. For control signals C'^C^O", 
the first sequence operates as a TYPE 1 LFSR. A first sequence of cells can thereby operate as a TYPE 1 LFSR and 
a second sequence can thereby operate as a TYPE 2 LFSR. 

it is possible to change any control signal during the propagation of path A, R and L Thereby, the polynomial char- 
acteristics can be changed, for example, depending on an output signal. For example, (a) during propagating path sig- 
40 rials A and R, an input signal sequence present at stage k1 is multiplied by a first characteristic polynomial function to 
an output signal sequence present at stage k3, and (b) during propagating path signals A and L ( an input signal 
sequence present at stage ki is divided by a second characteristic polynomial function to an output signal sequence 
present at stage K3. 

FIG. 8 shows a logic arrangement 45* (dashed frame) implemented according to equation (10) as it can also be 
45 used in cell 40. Analogies of inputs in FIGS. 8 and 4 are: 81 -3' to 81 -3 (connection 30*-i), 82-4' to 82-4 {connection 20- 
i), 82-3' to 82-3 (connection 1 0-), 84-3 and 83-3 combined to 87\ 84-4 and 83-4 combined to 87". Outputs 86-4 and 86- 
4' are corresponding. Preferably, logic arrangement 45* comprises xor-gate 76\ xor-gate76", and-gate 75' and and- 
gate 75". Ant^gate 75' with inputs 87' and 82-3* has output 85' coupled to input 87 of xor-gate 76*. Arid-gate 75" with 
inputs BT and 82-4' has output 85" coupled to input 87* of xor-gate 76*. Xor-gate 76' has output 89' coupled to input 
so 88' of xor-gate 76". Also, xor-gate 76" has input 81 -3' and output 86-4'. 

Arid-gate 75' receives R and C 3 and provides (R and C 3 ). Annate 75" receives C 4 and L and provides (L and 
C 4 ). Xor-gate 76' receives (R andC 3 ) and (L and €4) and provides ( (R and C3) xor (L and C 4 ) ). Xor-gate 76" receives 
A* and { (R and C 3 ) xor (L and C 4 ) ) and provides A** = A* xor ( (C3 and R) xor (C 4 and L) ). 

A particular feature of the present invention is the it makes it possible to provide a LFSR having, at the same time. 
£5 at least a first sequence operating in TYPE- 1 -MODE and a second sequence operating in TYPE-2-MODE. Also, the 
polynom degree can be programmed. For example, and not intended to be limiting, a LFSR can comprise cells 40-1 , 
40-2, 40-3 configured as 40#21 , 40#22, 40#20 and 40#12, respectively (cf. FIGS. 6-7). In that example, cells 40-1 and 
40-2 form the first sequence (TYPE 2) and cell 40-4 forms the second sequence (TYPE 1). 
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Although LFSR 300 of FIG. 3 receives a data signal at an input terminal (e.g., terminals 31, 11), the present, inven- 
tion is not limited to such LFSRs. The apparatus and method ot the present invention are also applicable tor other appli- 
cations without input, such as for random sequence generators, known by persons of skill in the art, 

While the extraction of an output signal has been illustrated at connection 30-n, persons of skill in the art will under- 
e stand based on the description herein, that an output signal can be obtained at any connection 30-i, 1 0-i, or 20-i or com- 
bination thereof. Processed data can also be obtained from two or more connections 30-i, 10-i or 20-i. Further, persons 
of skill in the art are able to include inverters or use inverse or other logical states without departing from the scope of 
the present invention. 

The LFSR of the present invention can also be used to calculate data by input-output function having more than n 
70 polynomials. Polynomial vectors longer than m can be divided into smaller subvectors. The calculation can be stepwise, 
as for example by: supplying input data, using a first subvector to calculate an intermediate result, storing the interme- 
diate result, supplying the intermediate result and using a second subvector to obtain a final result. 

LFSR 300 of the present invention is very useful, for example, in a digital signal processor (DSP). Once the poly- 
nom vector and the mode signal is obtained from e.g., a core of the DSP, LFSR 300 operates independently, thus saving 
is core resources. Data signals can be led forward and back simultaneously, what is needed e.g,. in the algorithms for the 
GSM cellular phone standard. A person of skill in the art can simplify LFSR 300 according to the needs of the applica- 
tion to further reduce costs by leaving out idle elements. When some characteristic polynomials are not applicable, than 
some of the gates can be left out. The invented arrangement can also be used to operate a first cell sequence in the 
first mode (TYPE 1) and another cell sequence in the second mode (TYPE 2). The present invention has the further 
20 advantage by virtue of its programmability of reducing the total amount of logic gates (and therfore chip are) required 
to implement multiple algorithm. 

Claims 

25 1 . A linear feecfcack shift register (LFSR. 300) characterised in: 

a propagation path (30) of serially coupled stages (65) and gates (80-3. 80-4); 
a feedforward path (10) of gates (80-1); and 
a feedback path of gates (80-2); 
30 wherein depending on control signals (P. M) the gates (80- 1 , 80-2, 80-3, 80-4) of said propagation, feedforward 

and feecfcack paths (30, 1 0, 20) are either active gates and operate as xor-gates or passive gates and operate 
as transfer gates. 

2. The LFSR (300) of claim 1 wherein feedforward and feedback signals (R it y are derived from input signals which 
35 are supplied to any of said stages (80-3, 80-4) of said propagation path (30). and wherein characteristic polynomi- 
als of an input-output function of said linear feedback shift register (300) are variable. 

3. The LFSR (300) claim 1 wherein feedforward and feedback signals (Rj, Lj ) are derived from output signals which 
are supplied to any of said stages (80-3. 80-4) of said propagation path (30), and wherein characteristic poiynomi- 

40 als of an input-output function of said linear feedback shift register (300) are variable. 

4. The LFSR (300) of claim 1 partly operating as a TYPE 1 or TYPE 2 LFSR and thereby simultaneously executing 
different algorithms. 

4$ 5. A method for processing signals by a serial arrangement of cells (40) kO » 1 to m with at least a first cell kl (40-kl ), 
a second ceil k2 (40-k2). and a third cell k3 (40-k3), with k2 £ kt+1 , k3 £ k2+1 the method comprising the steps of: 

providing a first control signal C* 1( a second control signal C* 2 , a third control signal C* 3 and fourth control sig- 
nal C* 4 for modifying the characteristic of said first, second, and third cells (40-k1 , 40-k2, 40-k3); 
so propagating a first path signal A in a first path (30) through the cells k1 , k2 and k3 in a first direction; 

propagating a second path signal R in a second path (10) through the cells k1 and k2 in said first direction, 
propagating a third path signal L in a third path through (20) the cells k2 and k3 in a second, opposite direction. 

6. The method of claim 5 wherein in said steps of propagating path signals A, R. L 

55 
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wherein in the step of propagating R, cell k1 modifies R K1 to R^ - (A^/z and CM) xor R H1 , which is further prop- 
agated to R K2 ; wherein in the step of propagating A, cell k2 modifies A^ to A^+i* A K2 /z xor (R k2 a/id C* 3 ) xor (L^ 
and C* 4 ) which is further propagated to A H3 ; and 

wherein in the step of propagating L cell k3 modifies to 1^3^ = (A k3 /2 and C* 2 ) xor L^ which is further propa- 
ne gated to L^, output signals being selectively derived from any of the cells. 

7. The method of claim 5 wherein said steps of propagating a second path signal R and propagating a third path sig- 
nal L are performed substantially simultaneously. 

?5 8, The method of claim 5 wherein under the condition that third and fourth control signals C* 3 and C* 4 are 
C VC*4=*Q tt . a f* rs * sequence of an arrangement defined by cells k2 and k3 operates as a TYPE 2 LFSR and 
wherein under the condition that first and second control signals C* t and C* 2 are C* 1 =C*2= n 0", said first sequence 
operates as a TYPE 1 LFSR. 

30 9, The method of claim 5 wherein a first sequence of cells operates as a TYPE 1 LFSR and a second sequence of 
cells operates as a TYPE 2 LFSR. 

1 0. The method of claim 5 wherein during execution of said steps of propagating first, second, and third path signaJs 
(30, 10, 20), said control signals can be changed. 
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(10) of gates (80-1) and a feedback path (20) of gates 
(80-2). Depending on control signals (P, B, M), the gates 
(80-1. 80-2. 80-3. 80-4) are either active gates and 
operate as xor-gates or passive gates and operate as 
transfer gates. Feedforward and feedback signals are 
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plied to any stage (65), so that characteristic polynomi- 
als of the input-output function are variable. The LFSR 
can fully or partly operate as a TYPE 1 or TYPE 2 LFSR 
which enables the execution of different algorithms on 
one hardware base. 
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